import { pointerCoord } from '../../../utils/helpers';
import { isFocused, relocateInput } from './common';
import { getScrollData } from './scroll-data';


export default function enableScrollAssist(
  componentEl: HTMLElement,
  inputEl: HTMLInputElement,
  contentEl: HTMLIonContentElement,
  keyboardHeight: number
) {
  let coord: any;
  const touchStart = (ev: UIEvent) => {
    coord = pointerCoord(ev);
    console.debug(`input-base, pointerStart, type: ${ev.type}`);
  };

  const touchEnd = (ev: UIEvent) => {
    // input cover touchend/mouseup
    console.debug(`input-base, pointerEnd, type: ${ev.type}`);
    if (!coord) {
      return;
    }
    // get where the touchend/mouseup ended
    const endCoord = pointerCoord(ev);

    // focus this input if the pointer hasn't moved XX pixels
    // and the input doesn't already have focus
    if (!hasPointerMoved(6, coord, endCoord) && !isFocused(inputEl)) {
      ev.preventDefault();
      ev.stopPropagation();

      // begin the input focus process
      jsSetFocus(componentEl, inputEl, contentEl, keyboardHeight);
    }
  };
  componentEl.addEventListener('touchstart', touchStart, true);
  componentEl.addEventListener('touchend', touchEnd, true);

  return () => {
    componentEl.removeEventListener('touchstart', touchStart, true);
    componentEl.removeEventListener('touchend', touchEnd, true);
  };
}

function jsSetFocus(
  componentEl: HTMLElement,
  inputEl: HTMLInputElement,
  contentEl: HTMLIonContentElement,
  keyboardHeight: number
) {
  const scrollData = getScrollData(componentEl, contentEl, keyboardHeight);
  if (Math.abs(scrollData.scrollAmount) < 4) {
    // the text input is in a safe position that doesn't
    // require it to be scrolled into view, just set focus now
    inputEl.focus();
    return;
  }

  // temporarily move the focus to the focus holder so the browser
  // doesn't freak out while it's trying to get the input in place
  // at this point the native text input still does not have focus
  relocateInput(componentEl, inputEl, true, scrollData.inputSafeY);
  inputEl.focus();

  // scroll the input into place
  contentEl.scrollByPoint(0, scrollData.scrollAmount, scrollData.scrollDuration, () => {
    // the scroll view is in the correct position now
    // give the native text input focus
    relocateInput(componentEl, inputEl, false, scrollData.inputSafeY);

    // ensure this is the focused input
    inputEl.focus();
  });
}

function hasPointerMoved(threshold: number, startCoord: PointerCoordinates, endCoord: PointerCoordinates) {
  if (startCoord && endCoord) {
    const deltaX = (startCoord.x - endCoord.x);
    const deltaY = (startCoord.y - endCoord.y);
    const distance = deltaX * deltaX + deltaY * deltaY;
    return distance > (threshold * threshold);
  }
  return false;
}

export interface PointerCoordinates {
  x?: number;
  y?: number;
}
